

## NEURAL NETWORK AND CIRCUIT THEREFOR

Publication number: JP7262157

Publication date: 1995-10-13

Inventor: MITSUGI SHIGERU

Applicant: KUMAMOTO TECHNOPOLIS FOUND

Classification:

- international: G06G7/60; G06F15/18; G06N3/06; G06G7/00;  
G06F15/18; G06N3/00; (IPC1-7): G06F15/18; G06G7/60

- European:

Application number: JP19940072745 19940317

Priority number(s): JP19940072745 19940317

[Report a data error here](#)

### Abstract of JP7262157

PURPOSE: To provide the neural network and the integrated circuit for this network which secure a high operation precision and have a small circuit scale and can be highly integrated by delaying a signal pulse to execute the multiplication of synapse coupling load.

CONSTITUTION: Data inputted to a neuron model is converted from a binary expression to an expression of the pulse interval between a reference pulse and the signal pulse by pulse generating circuits 141 to 14n after being subjected to logarithmic conversion by look-up tables 131 to 13n. Next, the signal pulse is delayed by a synapse coupling operation part to execute the multiplication of synapse coupling load to data inputted to the neuron model. Thereafter, data multiplied by the synapse coupling load is converted from the expression of the pulse interval between the reference pulse and the signal pulse to a binary expression and is subjected to exponential conversion by look-up tables and is inputted to the neuron model.



Data supplied from the **esp@cenet** database - Worldwide

(19)日本国特許庁 (JP)

(12) 公開特許公報 (A)

(11)特許出願公開番号

特開平7-262157

(43)公開日 平成7年(1995)10月13日

(51)Int.Cl.<sup>6</sup>

G 0 6 F 15/18  
G 0 6 G 7/60

識別記号 庁内整理番号

5 2 0 K 9 0 7 1 - 5 L

F I

技術表示箇所

(21)出願番号

特願平6-72745

(22)出願日

平成6年(1994)3月17日

審査請求 未請求 請求項の数10 FD (全22頁)

(71)出願人 591023158

財団法人熊本テクノポリス財団

熊本県上益城郡益城町大字田原2081番地10

(72)発明者 身次 茂

熊本県上益城郡益城町大字田原2081番地10

財団法人 熊本テクノポリス財団 電子  
応用機械技術研究所内

(74)代理人 弁理士 藤島 洋一郎

(54)【発明の名称】 ニューラルネットワークおよびそのための回路

(57)【要約】

【目的】 高い演算精度を確保しつつ、回路規模が小さく高集積化が可能なニューラルネットワークおよびそのための集積回路を提供する。

【構成】 ルックアップテーブル13によって、ニューロンモデルに対して入力するデータを対数変換したのち、そのデータを、パルス発生回路14によって基準パルスと信号パルスとのパルス間隔で表す。次いで、シナプス結合演算部22によって、信号パルスを遅延させ、ニューロンモデルに対して入力するデータへのシナプス結合荷重Wの乗算を実行する。その後、カウンタ2311によって、基準パルスと信号パルスとのパルス間隔により表されたデータを2進数に変換し、ルックアップテーブル2312によって、指数変換して、ニューロンモデルに入力する。





精度が高い反面、回路規模が大きいという問題点を有していた。

【0004】また、ニューラルネットワークには、デジタル回路によるもの以外にも、アナログ回路によるもの、光アナログ回路によるものまたはハードウェアではなくソフトウェアによるものがある。しかしながら、アナログ回路によるニューラルネットワークは、ニューロンモデルへの入力信号および出力信号をアナログ電圧により表現するので、回路規模が小さい反面、演算精度が低くシナプス結合荷重の変更も困難であるという問題点を有している。また、光アナログ回路によるニューラルネットワークは、ニューロンモデルへの入力信号および出力信号を光により表現するので、集光拡散や非干渉性などの光の特性により操作性を良くできる反面、アナログ回路と同様に演算精度が低いという問題点を有している。更に、ソフトウェアによるニューラルネットワークは、上述のハードウェアによるものの問題点を解決できる反面、処理速度が遅いという問題点を有している。

【0005】本発明はかかる問題点に鑑みてなされたもので、その目的は、高い演算精度を確保しつつ、回路規模が小さく高集積化が可能であり、加えて演算速度も速く、更にシナプス結合荷重の変更も容易なニューラルネットワークおよびそのための回路を提供することにある。

#### 【0006】

【課題を解決するための手段】請求項1記載のニューラルネットワークは、デジタル回路によって形成されたニューロンモデルの結合により構築され、前記ニューロンモデルにそれぞれ入力された少なくとも1以上のデータを前記各ニューロンモデルにおいて加算または減算のちシグモイド関数変換をしてなるニューラルネットワークにおいて、前記少なくとも1つのニューロンモデルに対して入力する2進数により表現されたデータを対数変換するための少なくとも1つの対数変換手段と、この対数変換手段により変換したデータを2進数による表現から基準パルスと信号パルスとのパルス間隔による表現に変換するための少なくとも1つのパルス発生手段と、前記ニューロンモデルに対して入力するデータへのシナプス結合荷重の乗算を前記パルス発生手段により発生された信号パルスを遅延させることにより実現するための少なくとも1つのシナプス結合演算手段と、このシナプス結合演算手段から出力されたデータを信号パルスと前記基準パルスとのパルス間隔による表現から2進数による表現に変換するための少なくとも1つの2進数変換手段と、この2進数変換手段により変換したデータを指数変換するための少なくとも1つの指数変換手段とを備えている。

【0007】このニューラルネットワークでは、対数変換手段によって、ニューロンモデルに対して入力するデータを対数変換したのち、そのデータを、パルス発生手

段によって2進数による表現から基準パルスと信号パルスとのパルス間隔による表現に変換する。次いで、シナプス結合演算手段によって、信号パルスを遅延させ、ニューロンモデルに対して入力するデータへのシナプス結合荷重の乗算を実行する。そののち、2進数変換手段によって、シナプス結合荷重の乗算されたデータを基準パルスと信号パルスとのパルス間隔による表現から2進数による表現に変換し、指数変換手段によって、指数変換して、ニューロンモデルに入力する。

【0008】請求項2記載のニューラルネットワークは、請求項1記載のものにおいて、前記シナプス結合演算手段が、信号パルスを遅延させるための遅延素子を備えている。

【0009】このニューラルネットワークでは、遅延素子によって、信号パルスを遅延させる。

【0010】請求項3記載のニューラルネットワークは、請求項2記載のものにおいて、前記シナプス結合演算手段が、更に、シナプス結合荷重がゼロのとき信号パルスを出力しないようにするための開閉スイッチを備えている。

【0011】このニューラルネットワークでは、開閉スイッチによって、シナプス結合荷重がゼロのとき信号パルスを出力しないようする。

【0012】請求項4記載のシナプス結合演算回路は、少なくとも1つのパルス入力端と、少なくとも1つの信号パルス出力端と、前記パルス入力端と前記信号パルス出力端とをそれぞれ互いに接続するための配線と、前記パルス入力端と前記信号パルス出力端との間にそれぞれ1つづつ挿入されて前記配線に対し直列に接続されており、ニューロンモデルへ入力するデータに対するシナプス結合荷重の乗算を信号パルスを遅延させることにより実現するための少なくとも1つのシナプス結合演算手段とを備えている。

【0013】このシナプス結合演算回路では、配線に接続されたシナプス結合演算手段によって、各パルス入力端に入力された信号パルスのそれぞれを遅延させ、各信号パルス出力端にそれぞれ出力する。

【0014】請求項5記載のシナプス結合演算回路は、請求項4記載のものにおいて、前記配線が、一端部が前記パルス入力端に1つづつ接続された少なくとも1つの入力ラインと、一端部が前記信号パルス出力端に1つづつ接続されており、少なくとも1以上の出力を1つにまとめて出力するための少なくとも1つのデータバスラインと、前記シナプス結合演算手段が直列に挿入されており、前記入力ラインと前記データバスラインとをそれぞれ接続するための少なくとも1つの接続ラインとを備えている。

【0015】このシナプス結合演算回路では、各入力ラインおよび各接続ラインによって、各パルス入力端に入力された信号パルスを各入力ラインに対して接続された

各シナプス結合演算手段にそれぞれ入力する。また、各接続ラインおよび各データバスラインによって、各データバスラインに対して接続された各シナプス結合演算手段により遅延された信号パルスを各信号パルス出力端にそれぞれ出力する。

【0016】請求項6記載のシナプス結合演算回路は、請求項5記載のものにおいて、前記配線が、前記シナプス結合演算手段と前記データバスラインとの間に挿入されており、前記接続ラインに対して直列に接続されたオープンコレクタ出力の少なくとも1つのインバータを更に備えている。

【0017】このシナプス結合演算回路では、オープンコレクタ出力のインバータによって、少なくとも1以上のシナプス結合演算手段の信号パルスをデータバスラインにまとめて出力端に出力する。

【0018】請求項7記載のシナプス結合演算回路は、請求項4ないし請求項6のいずれか1つに記載のものにおいて、前記シナプス結合演算手段が、信号パルスを遅延させるための遅延素子を備えている。

【0019】このシナプス結合演算回路では、遅延素子によって、信号パルスを遅延させる。

【0020】請求項8記載のシナプス結合演算回路は、請求項7記載のものにおいて、前記シナプス結合演算手段が、更に、シナプス結合荷重がゼロのとき信号パルスを出力しないようにするための開閉スイッチを備えている。

【0021】このシナプス結合演算回路では、開閉スイッチによって、シナプス結合荷重がゼロのとき信号パルスを出力しないようにする。

【0022】請求項9記載のニューロン演算回路は、信号パルスと基準パルスとのパルス間隔により表現された入力データを2進数で表現するための少なくとも1つの2進数変換手段と、この2進数変換手段により変換したデータを指數変換するための少なくとも1つの指數変換手段と、この指數変換手段により変換したデータを順次加算または減算したのちシグモイド関数変換を行うための少なくとも1つのニューロンモデルと、このニューロンモデルにより変換したデータを対数変換するための少なくとも1つの対数変換手段と、この対数変換手段により変換したデータを基準パルスと信号パルスとのパルス間隔で表現するための少なくとも1つのパルス発生手段とを備えている。

【0023】このニューロン演算回路では、2進数変換手段によって、ニューロンモデルに入力するシナプス結合荷重の乗算されたデータを基準パルスと信号パルスとのパルス間隔による表現から2進数による表現に変換し、指數変換手段によって、指數変換したのち、ニューロンモデルに入力する。次いで、ニューロンモデルによって、データを順次加算または減算したのちシグモイド関数変換を行う。次いで、対数変換手段によって、ニュ

ーロンモデルから出力するデータを対数変換したのち、そのデータを、パルス発生手段によって2進数による表現から基準パルスと信号パルスとのパルス間隔による表現に変換する。

【0024】請求項10記載のニューラルネットワークのための回路は、請求項4ないし請求項8のいずれか1つに記載のシナプス結合演算回路と、請求項9記載のニューロン演算回路とを備えている。

【0025】このニューラルネットワークのための回路では、シナプス結合演算手段によって、パルス入力端に入力された信号パルスを遅延させ、ニューロンモデルに入力するデータにシナプス結合荷重を乗算する。次いで、2進数変換手段によって、そのデータを基準パルスと信号パルスとのパルス間隔による表現から2進数による表現に変換したのち、指數変換手段によって、指數変換して、ニューロンモデルに入力する。そのち、ニューロンモデルによって、データを順次加算または減算したのちシグモイド関数変換を行う。更に次いで、対数変換手段によって、ニューロンモデルから出力するデータを対数変換したのち、パルス発生手段によって、2進数による表現から基準パルスと信号パルスとのパルス間隔による表現にそのデータを変換する。

【0026】

【実施例】以下、本発明の実施例について図面を参照して詳細に説明する。なお、ここにおいては、本発明の理解を容易とする目的で、階層型のニューラルネットワークを構築した場合について説明する。

【0027】(第1の実施例の構成)

【0028】図1は、第1の実施例に係るニューラルネットワークの全体構成を表すものである。本実施例のニューラルネットワークは、データの入力層として働くデータ入力装置10と、このデータ入力装置10の出力を入力とし所定の演算を行う中間層としての演算装置20と、この演算装置20の出力を入力とし所定の演算を行う出力層としての演算装置30と、この演算装置30の出力を入力としそれを表示するための表示装置40と、これらデータ入力装置10、演算装置20、30および表示装置40をそれぞれ制御するための制御装置50とを備えている。

【0029】データ入力装置10の構成

【0030】図2は、データ入力装置10の簡単な構成を表すものである。データ入力装置10では、識別対象(例えば、アルファベットの1文字)を複数の部分(以下、a個として説明する)に分割し、それぞれの部分の情報をデータとして演算装置20に対し出力する。

【0031】データ入力装置10は、a個の情報をそれぞれ認識するためのa個の認識素子11<sub>1</sub>, 11<sub>2</sub>, ..., 11<sub>a</sub>, ..., 11<sub>1</sub>, ..., 11<sub>a</sub>からなる入力デバイス11と、入力デバイス11により認識されたa個のデータを1つづつ保持するためのa個のレジスタ12<sub>1</sub>, 12<sub>2</sub>, ..., 12<sub>a</sub>, ...,

12<sub>1</sub>, ..., 12<sub>a</sub> と、レジスタ 12<sub>1</sub>, ..., 12<sub>a</sub>, ..., 12<sub>1</sub>, ..., 12<sub>a</sub> に 1つづつ対応されておりそれぞれに保持されたデータを対数変換するための a 個のルックアップテーブル 13<sub>1</sub>, ..., 13<sub>a</sub>, ..., 13<sub>1</sub>, ..., 13<sub>a</sub> と、ルックアップテーブル 13<sub>1</sub>, ..., 13<sub>a</sub>, ..., 13<sub>1</sub>, ..., 13<sub>a</sub> に 1つづつ対応されておりそれぞれの出力に応じて後述する基準パルス B<sub>10</sub> (図 3 参照) から遅延させた信号パルス S<sub>1</sub>, ..., S<sub>a</sub>, ..., S<sub>1</sub>, ..., S<sub>a</sub> を発生するための a 個のパルス発生回路 14<sub>1</sub>, ..., 14<sub>a</sub>, ..., 14<sub>1</sub>, ..., 14<sub>a</sub> とを備えている。入力デバイス 11 には、識別対象に応じて、キーボードやテレビカメラなど適宜のデバイスが選択される。

【0032】なお、各認識素子 11<sub>1</sub>, ..., 11<sub>a</sub>, ..., 11<sub>1</sub>, ..., 11<sub>a</sub>、各レジスタ 12<sub>1</sub>, ..., 12<sub>a</sub>, ..., 12<sub>1</sub>, ..., 12<sub>a</sub>、各ルックアップテーブル 13<sub>1</sub>, ..., 13<sub>a</sub>, ..., 13<sub>1</sub>, ..., 13<sub>a</sub>、および各パルス発生回路 14<sub>1</sub>, ..., 14<sub>a</sub>, ..., 14<sub>1</sub>, ..., 14<sub>a</sub> は、それぞれ同一の構成を有しているので、便宜上ここでは、認識素子 11<sub>1</sub> およびそれに対応するレジスタ 12<sub>1</sub>、ルックアップテーブル 13<sub>1</sub> ならびにパルス発生回路 14<sub>1</sub> を 20 代表して説明する (i = 1, 2, ..., a)。

【0033】図 3 は、認識素子 11<sub>1</sub>、レジスタ 12<sub>1</sub>、ルックアップテーブル 13<sub>1</sub> およびパルス発生回路 14<sub>1</sub> の具体的構成を表すものである。認識素子 11<sub>1</sub> は、制御装置 50 の指示に基づいて認識した情報を \*

$$LT_{131} = 50 \times \log_{10} R_{121} + 26 \quad (R_{121} \neq 0)$$

$$LT_{131} = R_{121} \quad (R_{121} = 0)$$

LT<sub>131</sub> ; アドレスに格納するデータ

R<sub>121</sub> ; アドレス (レジスタ 12<sub>1</sub> の保持データ) ※ 【表1】

| アドレス R <sub>121</sub><br>(レジスタ 12 <sub>1</sub> の<br>保持データ) | アドレスに格納<br>するデータ LT <sub>131</sub> | 信号パルス S <sub>i</sub> と<br>基準パルス B <sub>10</sub> との<br>パルス間隔 Ti' t |
|------------------------------------------------------------|------------------------------------|-------------------------------------------------------------------|
| 100                                                        | 126                                | 1t                                                                |
| ⋮                                                          | ⋮                                  | ⋮                                                                 |
| 10                                                         | 76                                 | 51t                                                               |
| ⋮                                                          | ⋮                                  | ⋮                                                                 |
| 1                                                          | 26                                 | 101t                                                              |
| 0                                                          | 0                                  | (パルスの発生無し)                                                        |

(各値は 10 進数にて表示)

【0037】パルス発生回路 14<sub>1</sub> は、パルス発生手段としての機能を有し、データ入力装置 10 から出力するデータを 2 進数による表現から基準パルス B<sub>10</sub> と信号パルス S<sub>1</sub> とのパルス間隔 (すなわち基準パルス B<sub>10</sub> に対する信号パルス S<sub>1</sub> の遅延時間) による表現に変換するためのものである。このパルス発生回路 14<sub>1</sub> は、クロック端 CLOCK の CLOCK 信号の立ち上がりにより、アップカウントを開始する 7 ビットのアップカウンタ UCNT<sub>141</sub> を備えている。アップカウンタ UCNT<sub>141</sub> は、ルックアップテーブル 13<sub>1</sub> の出力端 D<sub>0</sub> ~ D<sub>6</sub>

からアップカウント開始時のカウント値 LT<sub>0</sub> ~ LT<sub>6</sub> が入力されるデータ端 D<sub>0</sub> ~ D<sub>6</sub> と、カウント値が “1111111” (10 進数で 127) になると桁上げ信号 CARRY を出力する出力端 CARRY とを有している。アップカウンタ UCNT<sub>141</sub> は、また、制御装置 50 から SET\_UCNT 信号が入力されるロード端 LOAD を有している。この SET\_UCNT 信号は、データ端 D<sub>0</sub> ~ D<sub>6</sub> へのカウント値 LT<sub>0</sub> ~ LT<sub>6</sub> の読み込みを指示する信号である。

【0038】パルス発生回路 14<sub>1</sub> は、また、AND 1

$1_{141}$  を備えている。このAND  $1_{141}$  は、アップカウンタUCNT $1_{141}$  の有効端ENABLEに出力端が接続されており、信号“1”を出力することによりアップカウンタUCNT $1_{141}$  のCLOCK信号を立ち上げアップカウントを開始させるためのものである。AND  $1_{141}$  の第1の入力端には、AND  $2_{141}$  の出力端が接続されている。AND  $2_{141}$  は、ルックアップテーブル $1_{31}$  の出力LT $0$ ～LT $6$  の負論理の論理積をとりLT $0$ ～LT $6$  がすべて“0”的とき信号“0”を出力し、AND  $1_{141}$  の出力を“0”とすることによりアップカウンタUCNT $1_{141}$  のカウント動作を無効とするためのものである。AND  $1_{141}$  の第2の入力端には、フリップフロップFF $1_{141}$  の出力端Qが接続されている。フリップフロップFF $1_{141}$  は、制御装置50から入力端SETに基準パルスB $10$ が入力されると内部状態が“1”に設定され、OR $1_{141}$  から入力端CLEARに信号が入力されると内部状態が“0”に設定されるようになっている。OR $1_{141}$  は、第1の入力端にアップカウンタUCNT $1_{141}$  の出力端CARRYが、第2の入力端に制御装置50が接続されており、桁上げ信号CARRYおよびリセット信号RESETを通過させるようになっている。すなわち、フリップフロップFF $1_{141}$  は、基準パルスB $10$ が入力されると、AND  $2_{141}$  の出力が“1”であることを条件に、アップカウンタUCNT $1_{141}$  のカウント動作を開始させ、またリセット信号RESETおよび桁上げ信号CARRYがOR $1_{141}$  を介して入力されると、アップカウンタUCNT $1_{141}$  のカウント動作を無効とするためのものである。

【0039】なお、データ入力装置10から出力するデータを基準パルスB $10$ と信号パルスS $1$ とのパルス間隔 $T_{11} \sim t$ で表す理由は、後述するシナプス結合荷重 $W_{11}, W_{12}, \dots, W_{11}, \dots, W_{1b}$ が信号パルスS $1$ の遅延時間 $T_{11} t, T_{12} t, \dots, T_{11} t, \dots, T_{1b} t$ により表されるので、その乗算（ここでは対数変換されているので加算）を容易とすることにある。また、信号パルスS $1$ と基準パルスB $10$ とのパルス間隔 $T_{11} \sim t$ が $0 t$ からでなく $1 t$ とされているのは、後述のニューロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ のフリップフロップFF $2_{3111}, FF_{23112}, \dots, FF_{23113}, \dots, FF_{2311b}$ （図7参照）に基準パルスB $10$ と各信号パルスDS $1$ 、DS $2$ 、…、DS $1$ 、…、DS $b$ とが同時に入力され、セットとクリアを同時に実行する矛盾を回避するためである。

#### 【0040】演算装置20の構成

【0041】図4は、演算装置20の具体的構成を表すものである。演算装置20では、入力端S $1, S_2, \dots, S_1, \dots, S_b$ に対しデータ入力装置10から入力された信号パルスS $1, S_2, \dots, S_1, \dots, S_b$ を、複数のニューロン演算部（以下、b個として説明する） $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ にそれぞれ分配し、各ニュー

ロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ で所定の演算をしたのちその結果を演算装置30に対して出力する。

【0042】演算装置20は、各入力端S $1, S_2, \dots, S_1, \dots, S_b$ とb個のニューロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ の各入力端とをそれぞれ互いに接続するための配線21と、各入力端S $1, S_2, \dots, S_1, \dots, S_b$ と各ニューロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ との間にそれぞれ挿入された $a \times b$ 個のシナプス結合演算部 $2_{211}, 2_{212}, \dots, 2_{211}, \dots, 2_{21b}; 2_{221}, 2_{222}, \dots, 2_{221}, \dots, 2_{22b}; 2_{231}, 2_{232}, \dots, 2_{231}, \dots, 2_{23b}$ と、所定のシナプス結合演算部 $2_{211}, 2_{212}, \dots, 2_{213}, \dots, 2_{21b}; 2_{221}, 2_{222}, \dots, 2_{223}, \dots, 2_{22b}; 2_{231}, 2_{232}, \dots, 2_{233}, \dots, 2_{23b}$ の出力を入力とし所定の演算を行うためのb個のニューロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ とを備えている。各入力端S $1, S_2, \dots, S_1, \dots, S_b$ は、データ入力装置10の出力端V $1, V_2, \dots, V_1, \dots, V_b$ （すなわちアップカウンタUCNT $1_1, UCNT 1_2, \dots, UCNT 1_1, \dots, UCNT 1_b$ の各出力端）に1つづつ接続されている。

【0043】配線21は、一端部が各入力端S $1, S_2, \dots, S_1, \dots, S_b$ に1つづつ接続されたa本の入力ライン $2_{111}, 2_{112}, \dots, 2_{111}, \dots, 2_{11b}$ と、一端部がニューロン演算部 $2_{31}, 2_{32}, \dots, 2_{31}, \dots, 2_{3b}$ の入力端に1つづつ接続されたb本のデータバスライン $2_{121}, 2_{122}, \dots, 2_{121}, \dots, 2_{12b}$ とを備えている。各入力ライン $2_{111}, 2_{112}, \dots, 2_{111}, \dots, 2_{11b}$ は、各データバスライン $2_{121}, 2_{122}, \dots, 2_{121}, \dots, 2_{12b}$ に対しそれぞれ交差するように配設されている。この、各入力ライン $2_{111}, 2_{112}, \dots, 2_{111}, \dots, 2_{11b}$ は、それぞれ実質的に平行に配設されていることが好ましい。また、各データバスライン $2_{121}, 2_{122}, \dots, 2_{121}, \dots, 2_{12b}$ は、それぞれ実質的に平行に配設されていることが好ましい。更に、各入力ライン $2_{111}, 2_{112}, \dots, 2_{111}, \dots, 2_{11b}$ と各データバスライン $2_{121}, 2_{122}, \dots, 2_{121}, \dots, 2_{12b}$ とは、互いに格子状に交差していることが好ましい。

【0044】なお、各入力ライン $2_{111}, 2_{112}, \dots, 2_{111}, \dots, 2_{11b}$ と各データバスライン $2_{121}, 2_{122}, \dots, 2_{121}, \dots, 2_{12b}$ とは、それぞれ同一の構成により接続されているので、ここでは入力ライン $2_{111}$ とデータバスライン $2_{121}$ との接続部分の構成を代表して説明する（ $i = 1, 2, \dots, a; j = 1, 2, \dots, b$ ）。

【0045】入力ライン $2_{111}$ とデータバスライン $2_{121}$ とは、その交差部近傍において接続ライン $2_{113}$

により互いに接続されている。この接続ライン213<sub>11</sub>には、シナプス結合演算部22<sub>11</sub>が、直列に挿入されている。また、データバスライン212<sub>11</sub>とシナプス結合演算部22<sub>11</sub>との間には、ワイヤードORを形成するためのオープンコレクタ出力のインバータ214<sub>11</sub>が、接続ライン213<sub>11</sub>に対し直列に挿入されている。従つて、データバスライン212<sub>11</sub>の適宜な位置には、データバスライン212<sub>11</sub>に出力をする各インバータ214<sub>11</sub>、214<sub>21</sub>、…、214<sub>11</sub>、…、214<sub>11</sub>の共通負荷（すなわちブルアップ抵抗）215<sub>11</sub>が接続されている。

【0046】図5は、各シナプス結合演算部22<sub>11</sub>、2<sub>12</sub>、…、2<sub>211</sub>、…、2<sub>216</sub>；2<sub>221</sub>、2<sub>222</sub>、…、2<sub>223</sub>、…、2<sub>226</sub>；2<sub>231</sub>、2<sub>232</sub>、…、2<sub>233</sub>、…、2<sub>236</sub>；2<sub>241</sub>、2<sub>242</sub>、…、2<sub>243</sub>、…、2<sub>246</sub>の構成を表すものである。なお、各シナプス結合演算部22<sub>11</sub>、2<sub>212</sub>、…、2<sub>211</sub>、…、2<sub>216</sub>；2<sub>221</sub>、2<sub>222</sub>、…、2<sub>223</sub>、…、2<sub>226</sub>；2<sub>231</sub>、2<sub>232</sub>、…、2<sub>233</sub>、…、2<sub>236</sub>；2<sub>241</sub>、2<sub>242</sub>、…、2<sub>243</sub>、…、2<sub>246</sub>は、それぞれ同一の構成を有しているので、便宜上ここでは、シナプス結合演算部<sub>11</sub>を代表して説明する。

【0047】シナプス結合演算部22<sub>11</sub>は、シナプス結合演算手段としての機能を有する。ここでは、データ入力装置10から入力された信号パルスS<sub>11</sub>をシナプス結合荷重W<sub>11</sub>に対応した時間T<sub>11</sub>tだけ遅延させることにより、所定のシナプス結合荷重W<sub>11</sub>の乗算をする。このシナプス結合演算部22<sub>11</sub>は、シナプス結合荷重W<sub>11</sub>が0以外のときに信号パルスS<sub>11</sub>を所定の時間T<sub>11</sub>tだけ遅延させるための遅延素子22<sub>11</sub>と、シナプス結合荷重W<sub>11</sub>と、シナプス結合荷重W<sub>11</sub>の乗算を示す。

$$T_{11} = -50 \times \log_{10} |W_{11}| + 100 \quad (W_{11} \neq 0)$$

$$T_{11} = |W_{11}| \quad (W_{11} = 0)$$

【0050】開閉スイッチ22<sub>211</sub>は、接続ライン213<sub>11</sub>に対し直列に挿入されており、シナプス結合荷重W<sub>11</sub>が0のとき接続ライン213<sub>11</sub>を遮断し、シナプス結合荷重W<sub>11</sub>が0以外のとき接続ライン213<sub>11</sub>を接続するよう、制御装置50により制御されている。これは、シナプス結合荷重W<sub>11</sub>が0のときの遅延時間T<sub>11</sub>tを無限大とし、信号パルスDS<sub>11</sub>をシナプス結合演算部22<sub>11</sub>の出力としてインバータ214<sub>11</sub>に向かって（すなわちニューロン演算部23<sub>11</sub>に向かって）出力しないようするためである。これにより、シナプス結合荷重W<sub>11</sub>が0のときの乗算を容易に実行できる。なお、シナプス結合演算部22<sub>11</sub>において信号パルスS<sub>11</sub>を遅延する時間T<sub>11</sub>t（すなわち遅延素子22<sub>11</sub>と開閉スイッチ22<sub>211</sub>とにより遅延する時間）とシナプス結合荷重W<sub>11</sub>との対応関係を、表2に示す（各値は10進数にて表示する）。また、シナプス結合荷重W<sub>11</sub>に0を設定しない場合には、この開閉スイッチ22<sub>211</sub>は必要ない。

【0051】

50

\*重W<sub>11</sub>が0のときに信号パルスS<sub>11</sub>を無限時間遅延させるための開閉スイッチ22<sub>211</sub>とを備えている。すなわち、シナプス結合荷重W<sub>11</sub>は信号パルスS<sub>11</sub>を遅延させる時間T<sub>11</sub>tにより表現されており、シナプス結合荷重W<sub>11</sub>の乗算は信号パルスS<sub>11</sub>の遅延により実行されるようになっている。これにより、シナプス結合演算部22<sub>11</sub>のゲート数は、乗算器を用いて乗算を行う場合に比べ大幅に削減される。

【0048】遅延素子22<sub>11</sub>は、接続ライン213<sub>11</sub>に対し直列に挿入されている。遅延素子22<sub>11</sub>には、入力端INに入力された信号パルスS<sub>11</sub>を設定端D<sub>0</sub>～D<sub>6</sub>に設定された時間T<sub>11</sub>tだけ遅延させて出力端OUTから出力するプログラマブル遅延素子が用いられる。これは、遅延時間T<sub>11</sub>tを学習により任意に変更可能とするためである。遅延時間T<sub>11</sub>tは、設定端D<sub>0</sub>～D<sub>6</sub>に遅延時間T<sub>11</sub>tの係数T<sub>11</sub>が制御装置50から入力されたのち書込端WTに書き込みパルスが制御装置50から入力されることにより設定されるようになっている。遅延時間T<sub>11</sub>tの係数T<sub>11</sub>は、シナプス結合荷重W<sub>11</sub>を対数変換したものであり、シナプス結合荷重W<sub>11</sub>と式2に示す関係を有している。式2において、シナプス結合荷重W<sub>11</sub>を対数変換する理由は、シナプス結合荷重W<sub>11</sub>の乗算処理を加算処理に変換することにある。また、シナプス結合荷重W<sub>11</sub>について絶対値をとっているのも、同一の理由による。なお、本実施例では、シナプス結合荷重W<sub>11</sub>を-100～100の間で設定し、遅延時間T<sub>11</sub>tが100t～0tとなるように、式2の係数を定めている。

【0049】

【式2】

【表2】

| シナプス結合荷重W <sub>11</sub> | 遅延時間T <sub>11</sub> t |
|-------------------------|-----------------------|
| -100                    | 0t                    |
| ⋮                       | ⋮                     |
| -10                     | 50t                   |
| ⋮                       | ⋮                     |
| -1                      | 100t                  |
| 0                       | ∞（無限大）                |
| 1                       | 100t                  |
| ⋮                       | ⋮                     |
| 10                      | 50t                   |
| ⋮                       | ⋮                     |
| 100                     | 0t                    |

(各値は10進数にて表示)

【0052】図6は、ニューロン演算部23<sub>1</sub>, 23<sub>2</sub>, …, 23<sub>a</sub>の簡単な構成を表すものである。なお、各ニューロン演算部23<sub>1</sub>, 23<sub>2</sub>, …, 23<sub>a</sub>は、それぞれ同一の構成を有しているので、便宜上ここでは、ニューロン演算部23<sub>1</sub>を代表して説明する。

【0053】ニューロン演算部23<sub>1</sub>では、データバスライン212<sub>1</sub>を介して入力された信号パルスDS<sub>1</sub>・を順次加算または減算したのちしきい値を減算してから\*

$$V'_1 = g \left( \sum_{i=1}^{i=a} W_{ij} \times R_{12i} - h \right)$$

V<sub>1</sub>' : 演算結果 (対数変換していないニューロン演算部23<sub>1</sub>の出力データ)

g : シグモイド関数

R<sub>12i</sub> : データ入力装置10のレジスタ12<sub>i</sub>の保持データ

h : しきい値

【0055】ニューロン演算部23<sub>1</sub>は、信号パルスDS<sub>1</sub>・と基準パルスB<sub>10</sub>とのパルス間隔T<sub>1</sub>・tにより表現されたデータを指数変換するための変換回路23<sub>1</sub>と、変換回路23<sub>1</sub>の出力を順次加算または減算するための加減算回路23<sub>2</sub>と、加減算回路23<sub>2</sub>の演算結果に基づきシグモイド関数変換を行うためのシグモイド特性演算回路23<sub>3</sub>と、シグモイド特性演算回路23<sub>3</sub>の演算結果に応じてパルスを発生するためのパルス発生回路23<sub>4</sub>とを備えている。すなわち、本実施例においては、加減算回路23<sub>2</sub>とシグモイド特性演算回路23<sub>3</sub>とによりニューロンモデルを実現している。

【0056】図7は、変換回路23<sub>1</sub>の構成を表すものである。変換回路23<sub>1</sub>は、信号パルスDS<sub>1</sub>・と基準パルスB<sub>10</sub>とのパルス間隔T<sub>1</sub>・tにより表現されたデータを2進数による表現に変換する2進数変換手段としてのカウンタ2311<sub>1</sub>と、カウンタ2311<sub>1</sub>により測定されたカウント値CNT<sub>0</sub>～CNT<sub>7</sub>を指数変換する指数変換手段としてのルックアップテーブル2312<sub>1</sub>とを備えている。

【0057】カウンタ2311<sub>1</sub>は、クロック端CLOCKのCLOCK信号の立ち上がりにより“11001001”(10進数では202)からダウンカウントを開始する8ビットのダウンカウンタDCNT<sub>23111</sub>を備えている。ダウンカウンタDCNT<sub>23111</sub>は、制御装置50からダウンカウント開始時のカウント値“11001001”が入力されるデータ端D<sub>0</sub>～D<sub>7</sub>と、カウント値CNT<sub>0</sub>～CNT<sub>7</sub>を出力するカウント出力端Q<sub>0</sub>～Q<sub>7</sub>とを有している。ダウンカウンタDCNT<sub>23111</sub>は、また、制御装置50からSET\_DCNT信号が入力されるロード端LOADを有している。SET\_DCNT信号は、データ端D<sub>0</sub>～D<sub>7</sub>への“11001001”の読み込みを指示する信号である。なお、ダウンカ

\*その結果についてシグモイド関数変換をする。その演算式は、式3に示すとおりである。なお、信号パルスDS<sub>1</sub>・は、W<sub>11</sub> × R<sub>121</sub> (i = 1, 2, …, a) を対数変換したものの絶対値を表しているので、式3のW<sub>11</sub> × R<sub>121</sub>の加算は信号パルスDS<sub>1</sub>・を指數変換したものを順次加算または減算することにより達成される。

【0054】

【式3】

カウント開始時のカウント値“11001001”は、信号パルスDS<sub>1</sub>・と基準パルスB<sub>10</sub>とのパルス間隔T<sub>1</sub>・tが最大201tであることに基づいて定められている。

【0058】カウンタ2311<sub>1</sub>は、また、ダウンカウンタDCNT<sub>23111</sub>のカウント有効端ENABLEに出力端Qが接続されており、信号“1”を出力することによりダウンカウンタDCNT<sub>23111</sub>のCLOCK信号を立ち上げ、信号“0”を出力することによりダウンカウントを停止させるフリップフロップFF<sub>23111</sub>を備えている。フリップフロップFF<sub>23111</sub>は、制御装置50から入力端SETに基準パルスB<sub>10</sub>が入力されるとその内部状態が“1”に設定され、OR<sub>23111</sub>から入力端CLEARに信号が入力されると内部状態が“0”に設定されるようになっている。OR<sub>23111</sub>は、第1の入力端にデータバスライン212<sub>1</sub>が、第2の入力端に制御装置50が、第3の入力端にダウンカウンタDCNT<sub>23111</sub>の出力端Borrowが接続されており、信号パルスDS<sub>1</sub>・、リセット信号RESETおよび桁借り信号Borrowを通過させようになっている。すなわち、フリップフロップFF<sub>23111</sub>は、基準パルスB<sub>10</sub>が入力されると、ダウンカウンタDCNT<sub>23111</sub>のカウント動作を開始させ、信号パルスDS<sub>1</sub>・、リセット信号RESETまたは桁借り信号BorrowがOR<sub>23111</sub>を介して入力されると、ダウンカウンタDCNT<sub>23111</sub>のカウント動作を無効とするためのものである。

【0059】信号パルスDS<sub>1</sub>・と基準パルスB<sub>10</sub>とのパルス間隔T<sub>1</sub>・tと、ダウンカウンタDCNT<sub>23111</sub>のカウント値CNT<sub>0</sub>～CNT<sub>7</sub>との関係は、表3に示すとおりとなる(各値は10進数にて表示する)。

【0060】

【表3】

| 信号パルス DS <sub>j</sub> * と<br>基準パルス B10 との<br>パルス間隔 T <sub>j</sub> *t | カウント値<br>CNT <sub>2311j</sub><br>(アドレス) | アドレスに格納<br>するデータ LT <sub>2312j</sub> |
|----------------------------------------------------------------------|-----------------------------------------|--------------------------------------|
| 1t                                                                   | 201                                     | 10000                                |
| ⋮                                                                    | ⋮                                       | ⋮                                    |
| 51t                                                                  | 151                                     | 1000                                 |
| ⋮                                                                    | ⋮                                       | ⋮                                    |
| 101t                                                                 | 101                                     | 100                                  |
| ⋮                                                                    | ⋮                                       | ⋮                                    |
| 151t                                                                 | 51                                      | 10                                   |
| ⋮                                                                    | ⋮                                       | ⋮                                    |
| 201t                                                                 | 1                                       | 1                                    |
| 無限大(信号パルスなし)                                                         | 0                                       | 0                                    |

(各値は10進数にて表示)

【0061】ルックアップテーブル2312; は、メモリRAM<sub>2312j</sub>により構成されている。このメモリRAM<sub>2312j</sub>は、ダウンカウンタDCNT<sub>2311j</sub>のカウント出力端Q<sub>0</sub>～Q<sub>7</sub>にアドレス入力端AD<sub>0</sub>～AD<sub>7</sub>が接続されており、アドレス入力端AD<sub>0</sub>～AD<sub>7</sub>にアドレス(すなわちカウント値)CNT<sub>0</sub>～CNT<sub>7</sub>が入力されると、アドレスCNT<sub>0</sub>～CNT<sub>7</sub>に格納されたデータLT<sub>0</sub>～LT<sub>13</sub>をデータ出力端D<sub>0</sub>～D<sub>13</sub>から出力するものである。メモリRAM<sub>2312j</sub>の各アドレスCNT<sub>0</sub>～CNT<sub>7</sub>に格納されるデータLT<sub>0</sub>～LT<sub>13</sub>は、カウント値CNT<sub>0</sub>～CNT<sub>7</sub>と式4に示す関係を有している。その対応関係を表3に表す。ここで指数変換を行うのは、対数変換されているW<sub>1j</sub>R<sub>121</sub>, W<sub>2j</sub>R<sub>122</sub>, …, W<sub>ij</sub>R<sub>121</sub>, …, W<sub>sj</sub>R<sub>12s</sub>をもとにもどすためである。

【0062】

【式4】

$$LT_{2312j} = 10^{(CNT_{2311j} - 1) / 50}$$

LT<sub>2312j</sub> : アドレスに格納するデータ  
CNT<sub>2311j</sub> : アドレス

【0063】図8は、加減算回路232; の構成を表すものである。加減算回路232; は、一方の入力端A<sub>0</sub>～A<sub>13</sub>への入力または他方の入力端B<sub>0</sub>～B<sub>13+s</sub>への入力のいずれか一方を出力とするための選択回路2321; と、一方の入力端A<sub>0</sub>～A<sub>13+s</sub>への入力を他方の入力端B<sub>0</sub>～B<sub>13+s</sub>への入力に対し加算または減算するための加減算器2322; と、加減算器2322; の出力を保持するためのレジスタ2323; とを備えている。

【0064】選択回路2321; は、入力端A<sub>0</sub>～A<sub>13</sub>への入力または入力端B<sub>0</sub>～B<sub>13+s</sub>への入力のいずれを出力とするかを選択するための選択端SELECTを有

している。この選択端SELECTは、制御装置50に接続されている。また、選択回路2321; の一方の入力端A<sub>0</sub>～A<sub>13</sub>には、変換回路231; の出力LT<sub>0</sub>～LT<sub>13</sub>が入力されるように変換回路231; の出力端D<sub>0</sub>～D<sub>13</sub>が接続されている。選択回路2321; の他方の入力端B<sub>0</sub>～B<sub>13+s</sub>には、制御装置50に記憶されたしきい値H<sub>0</sub>～H<sub>13+s</sub>が入力されるように制御装置50の出力端が接続されている。

【0065】加減算器2322; は、入力端A<sub>0</sub>～A<sub>13+s</sub>への入力を入力端B<sub>0</sub>～B<sub>13+s</sub>への入力に対し加算するのか減算するのかを指示するための制御端ADD/SUBを有している。この制御端ADD/SUBは、制御装置50に接続されており、シナプス結合荷重W<sub>1j</sub>, W<sub>2j</sub>, …, W<sub>ij</sub>, …, W<sub>sj</sub>が正の値のときは加算を指示し、負の値のときは減算を指示するように制御されている。また、加減算器2322; の一方の入力端A<sub>0</sub>～A<sub>13+s</sub>には、選択回路2321; の出力が入力されるよう選択回路2321; の出力端Y<sub>0</sub>～Y<sub>13+s</sub>が接続されている。加減算器2322; の他方の入力端B<sub>0</sub>～B<sub>13+s</sub>には、レジスタ2323; の出力R<sub>0</sub>～R<sub>13+s</sub>が入力されるようレジスタ2323; の出力端Q<sub>0</sub>～Q<sub>13+s</sub>が接続されている。なお、この加減算器2322; は、14ビットのデータについてb回加算または減算をおこなうので、オーバーフローを生じないように、14+mビットが必要とされる。mは式5により求められる値である。

【0066】

【式5】 $m = \log_2 b$ 

【0067】レジスタ2323; は、クリア端CLEARに信号CLR\_REGが入力されると内部の保持データがクリアされ、書込端WTに信号WT\_REGが入力されるとその時データ入力端D<sub>0</sub>～D<sub>13+s</sub>に入力されて

いるデータを内部に保持する記憶素子である。クリア端 CLEAR および書込端WTは、ともに制御装置50に接続されている。また、データ入力端D<sub>0</sub>～D<sub>13+n</sub>は、加減算器2322<sub>1</sub>の出力端S<sub>0</sub>～S<sub>13+n</sub>に接続されている。

【0068】図9は、シグモイド特性演算回路233<sub>1</sub>の構成を表すものである。シグモイド特性演算回路233<sub>1</sub>は、メモリRAM<sub>2331</sub>により構成されている。このメモリRAM<sub>2331</sub>は、加減算回路232<sub>1</sub>のレジスタ2323<sub>1</sub>の出力端Q<sub>0</sub>～Q<sub>13+n</sub>にアドレス入力端AD<sub>0</sub>～AD<sub>13+n</sub>を接続する。

$$D_{2331} = 50 \times \log_{10} \{ g (R_{23231}) \} + 26$$

$$= 50 \times \log_{10} [1 / (1 + \exp (-R_{23231}))] + 26$$

$$(g (R_{23231}) \neq 0)$$

$$(g (R_{23231}) = 0)$$

$$D_{2331} = g (R_{23231})$$

g : シグモイド関数

D<sub>2331</sub> : アドレスに格納するデータ

R<sub>23231</sub> : アドレス (但し下m桁は切り捨てる)

【0070】式6中のgは、シグモイド関数であり、図10に示す特性を有している。すなわち、シグモイド関数gは、加減算回路232<sub>1</sub>のレジスタ2323<sub>1</sub>の保持データR<sub>0</sub>～R<sub>13+n</sub>を0～100の間の適宜な値に変換することになる。また、レジスタ2323<sub>1</sub>の出力R<sub>0</sub>～R<sub>13+n</sub>のうちR<sub>0</sub>～R<sub>n-1</sub>を使用しない理由は、演算精度に影響を与えることのない下位の桁の値を切り捨てるにより、演算を簡素化することにある。なお、シグモイド特性演算回路233<sub>1</sub>では、式6に示すとおり、対数変換も同時に実行しており、対数変換手段としての機能も有している。これは、演算装置20がデータ入力装置10と同様に、基準パルスB<sub>20</sub>に対して遅延させた信号パルスS<sub>1</sub>により出力を行うためである。式6による対数変換は、データ入力装置10のルックアップテーブル13<sub>1</sub>の式1による対数変換と同一である。

【0071】図11は、パルス発生回路234<sub>1</sub>の構成を表すものである。パルス発生回路234<sub>1</sub>は、パルス発生手段としての機能を有し、シグモイド特性演算回路233<sub>1</sub>の出力値G<sub>0</sub>～G<sub>6</sub>から“1111111”(10進数で127)までカウントアップを行い信号パルスS<sub>1</sub>出力するためのものである。その構成は、データ入力装置10のパルス発生回路14<sub>1</sub>と同一であるので、同一の構成要素については、添字を234<sub>1</sub>に変え同一の符号を付して、その詳細な説明は省略する。

#### 【0072】演算装置30の構成

【0073】図12は、演算装置30の構成を表すものである。演算装置30では、入力端S<sub>1</sub>, S<sub>2</sub>, ..., S<sub>1</sub>, ..., S<sub>b</sub>に対し演算装置20から入力された信号パルスS<sub>1</sub>, S<sub>2</sub>, ..., S<sub>1</sub>, ..., S<sub>b</sub>を、複数のニューロン演算部(以下、c個として説明する)33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>にそれぞれ分配し、各ニューロン演算部33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>で所定の演算をしたのちその結果を表示装置40に対して出力する。

\*～AD<sub>13</sub>が接続されており、アドレス入力端AD<sub>0</sub>～AD<sub>13</sub>にアドレスR<sub>0</sub>～R<sub>13+n</sub>が入力されると、そのアドレスR<sub>0</sub>～R<sub>13+n</sub>に格納されたデータD<sub>0</sub>～D<sub>6</sub>をデータ出力端D<sub>0</sub>～D<sub>6</sub>から出力するものである。メモリRAM<sub>2331</sub>の各アドレスR<sub>0</sub>～R<sub>13+n</sub>に格納されたデータD<sub>0</sub>～D<sub>6</sub>は、アドレス(すなわちレジスタ2323<sub>1</sub>の保持データ)R<sub>0</sub>～R<sub>13+n</sub>値と式6に示す関係を有している。

#### 【0069】

#### 【式6】

【0074】演算装置30は、演算装置20と同様に、各入力端S<sub>1</sub>, S<sub>2</sub>, ..., S<sub>1</sub>, ..., S<sub>b</sub>とc個のニューロン演算部33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>, ..., 33<sub>b</sub>の各入力端とをそれぞれ互いに接続するための配線31と、各入力端S<sub>1</sub>, S<sub>2</sub>, ..., S<sub>1</sub>, ..., S<sub>b</sub>と各ニューロン演算部33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>, ..., 33<sub>b</sub>との間にそれぞれ挿入されたb×c個のシナプス結合演算部32<sub>11</sub>, 32<sub>12</sub>, ..., 32<sub>1k</sub>, ..., 32<sub>1c</sub>; 32<sub>21</sub>, 32<sub>22</sub>, ..., 32<sub>2k</sub>, ..., 32<sub>2c</sub>; 32<sub>31</sub>, 32<sub>32</sub>, ..., 32<sub>3k</sub>, ..., 32<sub>3c</sub>; 32<sub>b1</sub>, 32<sub>b2</sub>, ..., 32<sub>bk</sub>, ..., 32<sub>bc</sub>と、所定のシナプス結合演算部32<sub>11</sub>, 32<sub>12</sub>, ..., 32<sub>1k</sub>, ..., 32<sub>1c</sub>; 32<sub>21</sub>, 32<sub>22</sub>, ..., 32<sub>2k</sub>, ..., 32<sub>2c</sub>; 32<sub>31</sub>, 32<sub>32</sub>, ..., 32<sub>3k</sub>, ..., 32<sub>3c</sub>; 32<sub>b1</sub>, 32<sub>b2</sub>, ..., 32<sub>bk</sub>, ..., 32<sub>bc</sub>の出力を入力とし所定の演算を行うためのc個のニューロン演算部33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>, ..., 33<sub>b</sub>とを備えている。各入力端S<sub>1</sub>, S<sub>2</sub>, ..., S<sub>1</sub>, ..., S<sub>b</sub>は、演算装置20の出力端V<sub>1</sub>, V<sub>2</sub>, ..., V<sub>1</sub>, ..., V<sub>b</sub>(すなわちアップカウンタUCNT<sub>2341</sub>, UCNT<sub>2342</sub>, ..., UCNT<sub>2343</sub>, ..., UCNT<sub>234b</sub>の各出力端)に1つづつ接続されている。

【0075】配線31は、入力ライン311<sub>1</sub>, 311<sub>2</sub>, ..., 311<sub>1</sub>, ..., 211<sub>b</sub>の本数がb本に、データバスライン312<sub>1</sub>, 312<sub>2</sub>, ..., 312<sub>c</sub>, ..., 312<sub>b</sub>の本数がc本に、その他の構成要素についてもそれに対応して数が変更されたことを除き、演算装置20の配線21と同一の構成を有している。

【0076】シナプス結合演算部32<sub>11</sub>, 32<sub>12</sub>, ..., 32<sub>1k</sub>, ..., 32<sub>1c</sub>; 32<sub>21</sub>, 32<sub>22</sub>, ..., 32<sub>2k</sub>, ..., 32<sub>2c</sub>; 32<sub>31</sub>, 32<sub>32</sub>, ..., 32<sub>3k</sub>, ..., 32<sub>3c</sub>; 32<sub>b1</sub>, 32<sub>b2</sub>, ..., 32<sub>bk</sub>, ..., 32<sub>bc</sub>は、その数がb×c個に変更されたことを除き、演算装置20のシナプス結合演算部22<sub>11</sub>と同一の構成をそれぞれ有している。

【0077】図13は、ニューロン演算部33<sub>1</sub>, 33<sub>2</sub>, ..., 33<sub>c</sub>, ..., 33<sub>b</sub>の簡単な構成を表すものであ

る。各ニューロン演算部  $33_1, 33_2, \dots, 33_n, \dots, 33_c$  は、それぞれ同一の構成を有しているので、便宜上ここでは、ニューロン演算部  $33_1$  を代表して説明する。

【0078】ニューロン演算部  $33_1$  は、シグモイド特性演算回路  $33_{31}$  で行われる演算の内容が相違し、かつパルス発生回路を備えていないことを除き、演算回路  $20$  のニューロン演算部  $23_1$  と同一の構成を有している。パルス発生回路を備えていないのは、演算装置  $30$  は表示装置  $40$  に対し出力を行い、表示装置  $40$  ではその表示を行うのみだからである。

【0079】シグモイド特性演算回路  $33_{31}$  は、演算回路  $20$  のシグモイド特性演算回路  $23_{31}$  と同様に、メモリ  $RAM_{3331}$  により構成されている。このメモリ  $RAM_{3331}$  の各アドレス  $R_0 \sim R_{13+0}$  に格納されたデータ  $D_0 \sim D_6$  は、各アドレス  $R_0 \sim R_{13+0}$  値と式7に示す関係を有している。すなわち、式7は、対数変換を行わないことを除き、式6と同一である。対数変換を行わない理由は、パルス発生回路を備えていない理由と同一である。

【0080】

$$【式7】 D_{3331} = g(R_{33231}) = 1 / \{1 + \exp(-R_{33231})\}$$

$g$  ; シグモイド関数

$D_{3331}$  ; アドレスに格納するデータ

$R_{33231}$  ; アドレス (但し下n桁は切り捨てる)

【0081】表示装置  $40$  の構成

【0082】表示装置  $40$  では、入力端  $I_1, I_2, \dots, I_n, \dots, I_c$  に対し演算装置  $30$  から入力された信号パルス  $I_1, I_2, \dots, I_k, \dots, I_c$  を、適宜の手段により表示する。表示装置  $40$  には、ディスプレイやプリンタなどの適宜の手段が用いられる。その入力端  $I_1, I_2, \dots, I_k, \dots, I_c$  は、演算装置  $30$  の出力端  $G_1, G_2, \dots, G_k, \dots, G_c$  (すなわちメモリ  $RAM_{3331}, RAM_{3332}, \dots, RAM_{3331}, \dots, RAM_{333c}$  の各出力端) に1つづつ接続されている。

【0083】制御装置  $50$  の構成

【0084】制御装置  $50$  は、演算装置  $20, 30$  に対しそれぞれ供給するデータを記憶するための記憶回路と、データ入力装置  $10$ 、演算装置  $20, 30$  および表示装置  $40$  をそれぞれ制御するための制御信号を発生する制御信号発生回路とを備えている。記憶回路は、各シナップス結合演算部  $22, 32$  に対応したシナップス結合荷重  $W$  を記憶するためのメモリと、シナップス結合荷重  $W$  を式2の対数変換するためのルックアップテーブルとを備えている。

【0085】(第1の実施例の作用) 次に、第1の実施例について、その動作および演算速度について説明しつつ、その作用を説明する。

【0086】初期準備動作

【0087】本実施例のニューラルネットワークは、その処理動作に先立ち、制御装置  $50$  により、リセット信号  $RESET$  およびセット信号  $SET\_DCNT, SET\_UCNT, CLR\_REG$  が発生される。これにより、データ入力装置  $10$  および演算装置  $20, 30$  のフリップフロップ  $FF$ 、アップカウンタ  $UCNT$ 、ダウンカウンタ  $DCNT$  およびレジスタは、初期状態にそれぞれ設定される。また、データ入力装置  $10$  および演算装置  $20, 30$  のメモリ  $RAM$  ならびに制御装置  $50$  の記憶回路には、それぞれの構成の説明において説明した所定のデータが記憶される。

【0088】処理動作

【0089】初期準備動作が終了すると、本実施例のニューラルネットワークは、制御装置  $50$  の指示により、まずデータ入力装置  $10$  が、識別対象 (例えば、アルファベットの1文字) を認識し、そのデータを演算装置  $20$  に対して出力する。次いで、演算装置  $20$  が、その入力に基づき所定の演算を行い、その結果を演算装置  $30$  に対して出力する。更に、演算装置  $30$  が、その入力に基づき所定の演算を行い、その結果を表示装置  $40$  に対して出力する。最後に、表示装置  $40$  が、その入力に基づきその結果を表示する。以下、各装置における処理動作について、それぞれ説明する。

【0090】データ入力装置  $10$  での処理動作

【0091】図14および図15は、データ入力装置  $10$  での処理動作の流れを表すものである。データ入力装置  $10$  では、まず、各認識素子  $11_1, 11_2, \dots, 11_n, \dots, 11_c$  が制御装置  $50$  から制御信号を受信すると、識別対象を認識し、その情報を2進数の適宜のデータに変換する。そののち、各認識素子  $11_1, 11_2, \dots, 11_n, \dots, 11_c$  は、データを各レジスタ  $12_1, 12_2, \dots, 12_n, \dots, 12_c$  に対してそれぞれ出力する (ステップS101)。

【0092】各レジスタ  $12_1, 12_2, \dots, 12_n, \dots, 12_c$  は、各認識素子  $11_1, 11_2, \dots, 11_n, \dots, 11_c$  からデータが入力されると、そのデータを保持するとともに、各ルックアップテーブル  $13_1, 13_2, \dots, 13_n, \dots, 13_c$  に対して出力する (ステップS102)。

【0093】各ルックアップテーブル  $13_1, 13_2, \dots, 13_n, \dots, 13_c$  は、各レジスタ  $12_1, 12_2, \dots, 12_n, \dots, 12_c$  からアドレス (すなわち保持データ)  $R_0 \sim R_6$  が入力されると、そのアドレス  $R_0 \sim R_6$  に格納されたデータ  $LT_0 \sim LT_6$  を読み出し、各アップカウンタ  $UCNT_{141}, UCNT_{142}, \dots, UCNT_{14n}, \dots, UCNT_{14c}$  に対して出力する。これにより、各レジスタ  $12_1, 12_2, \dots, 12_n, \dots, 12_c$  の保持データ  $R_0 \sim R_6$  が対数変換される (ステップS103)。

【0094】各アップカウンタ  $UCNT_{141}, UCNT_{142}, \dots, UCNT_{14n}, \dots, UCNT_{14c}$  は、制御装置

21

50からSET\_UCNT信号を受信すると、各ルックアップテーブル $13_1, 13_2, \dots, 13_1, \dots, 13_1$ の出力データ $LT_0 \sim LT_6$ をデータ端 $D_0 \sim D_6$ に読み込む（ステップS104）。

【0095】次いで、1つのパルス発生回路 $14_1$ に制御装置50から基準パルス $B_{10}$ が発信され、フリップフロップ $FF_{141}$ の入力端SETに入力されると、フリップフロップ $FF_{141}$ はその内部状態が“1”に設定され、AND $1_{141}$ に出力端Qから信号“1”を出力はじめる（ステップS105）。

【0096】このとき、ルックアップテーブル $13_1$ の出力信号 $LT_0 \sim LT_6$ がすべて“0”であると（ステップS106；Y）、AND $2_{141}$ はAND $1_{141}$ に対して信号“0”を出力するので、AND $1_{141}$ はアップカウンタUCNT $1_{141}$ の有効端ENABLEに信号“0”を出力する。アップカウンタUCNT $1_{141}$ は、有効端ENABLEに信号“0”が入力されると、カウント動作を無効とする（ステップS107）。すなわち、アップカウンタUCNT $1_{141}$ は、演算装置20に対して信号パルス $S_1$ を出力しない。

【0097】逆に、ルックアップテーブル $13_1$ の出力信号 $LT_0 \sim LT_6$ がすべて“0”でないと（ステップS106；N）、AND $2_{141}$ はAND $1_{141}$ に対して信号“1”を出力するので、AND $1_{141}$ はアップカウンタUCNT $1_{141}$ の有効端ENABLEに信号“1”を出力する。アップカウンタUCNT $1_{141}$ は、有効端ENABLEに信号“1”が入力されると、CLOCK信号を立ち上げ、入力端 $D_0 \sim D_6$ に入力されたカウント値（すなわちルックアップテーブル $13_1$ の出力データ） $LT_0 \sim LT_6$ からアップカウントを開始する（図16(a)(b)参照）。適宜の時間経過ののち、アップカウンタUCNT $1_{141}$ は、カウント値が“1111111”となると、桁上げ信号CARRYを“0”から“1”とし、出力端CARRYから演算装置20に対して桁上げ信号CARRYを出力はじめる（図16(c)参照）。アップカウンタUCNT $1_{141}$ は、また、桁上げ信号CARRYをOR $1_{141}$ を介してフリップフロップ $FF_{141}$ に出力し、その内部状態を“0”に設定する。フリップフロップ $FF_{141}$ は、AND $1_{141}$ を介してアップカウンタUCNT $1_{141}$ の有効端ENABLEに信号

“0”を出力し、アップカウンタUCNT $1_{141}$ のカウント動作を無効とする。これにより、アップカウンタUCNT $1_{141}$ は、桁上げ信号CARRYを“1”から“0”とし、演算装置20に対して桁上げ信号CARRYの出力を停止する。従って、アップカウンタUCNT $1_{141}$ は、信号パルス $S_1$ を基準パルス $B_{10}$ から所定の時間遅延させて、演算装置20に対し出力することになる。これにより、対数変換されたレジスタ $12_1$ の保持データが、2進数による表現から信号パルス $S_1$ と基準パルス $B_{10}$ とのパルス間隔 $T_1$ 、 $t$ による表現に変換さ

22

れる。この信号パルス $S_1$ は、データ入力装置10の出力端 $V_1$ から演算装置20に対して出力される（ステップS108）。ちなみに、図16では、ルックアップテーブル $13_1$ の出力が“1111100”である場合を表している。

【0098】1つのパルス発生回路 $14_1$ に制御装置50から基準パルス $B_{10}$ が発信されて所定の時間の経過ののち（ステップS109；Y）、次の1つのパルス発生回路 $14_{1+1}$ に制御装置50から基準パルス $B_{10}$ が発信されると、次の1つのパルス発生回路 $14_{1+1}$ も1つのパルス発生回路 $14_1$ と同様にステップS105～ステップS108の動作をする。このようにして、全てのパルス発生回路 $14_1, 14_2, \dots, 14_1, \dots, 14_1$ が動作する（ステップS110）。なお、基準パルス $B_{10}$ は、一定の間隔で発生されていることが好ましい。また、この間隔は、 $202t$ 以上であることが好ましい。

#### 【0099】演算装置20での処理動作

【0100】図17および図18は、演算装置20での処理動作の流れを表すものである。なお、各シナプス結合演算部 $22_{11}, 22_{12}, \dots, 22_{11}, \dots, 22_{16}$ および各ニューロン演算部 $23_1, 23_2, \dots, 23_1, \dots, 23_6$ は、基準パルス $B_{10}$ および1つの信号パルス $S_1$ が入力されると、それぞれ平行して同様の処理を行うので、ここでは、シナプス結合演算部 $22_{11}$ およびニューロン演算部 $23_1$ を代表して説明する。

【0101】演算装置20では、まず、各ニューロン演算部 $23_1, 23_2, \dots, 23_1, \dots, 23_6$ の各変換回路 $23_{11}, 23_{12}, \dots, 23_{11}, \dots, 23_{16}$ に制御装置50から基準パルス $B_{10}$ が発信される。この基準パルス $B_{10}$ は、データ入力装置10のフリップフロップ $FF_{141}$ に制御装置50から発信された基準パルス $B_{10}$ と同一である。変換回路 $23_{11}$ のカウンタ $23_{11}$ では、フリップフロップ $FF_{23_{11}}$ の入力端SETに基準パルス $B_{10}$ が入力される。フリップフロップ $FF_{23_{11}}$ は、その内部状態が“1”に設定され、ダウンカウンタDCNT $23_{11}$ の各有効端ENABLEに信号“1”を出力はじめる。ダウンカウンタDCNT $23_{11}$ は、これにより、CLOCK信号を立ち上げ、“11001001”からダウンカウントをそれぞれ開始する（ステップS201）。

【0102】適宜の時間の経過ののち、データ入力装置10から信号パルス $S_1$ が演算装置20の入力端 $S_1$ に入力されると、入力ライン $211_1$ および各接続ライン $213_{11}, 213_{12}, \dots, 213_{11}, \dots, 213_{16}$ を介して各シナプス結合演算部 $22_{11}, 22_{12}, \dots, 22_{11}, \dots, 22_{16}$ に信号パルス $S_1$ が入力される（ステップS202）。

【0103】シナプス結合演算部 $22_{11}$ の遅延素子 $22_{11}$ は、入力端INに信号パルス $S_1$ が入力されると、設定された遅延時間 $T_{11}t$ だけ信号パルス $S_1$ を遅延さ

せて、出力端OUTからインバータ214<sub>11</sub>に対して信号パルスDS<sub>11</sub>を出力する(図16(d)参照; ちなみに、図16では、遅延時間T<sub>11</sub> tが4tである場合について表している)。これにより、シナプス結合荷重W<sub>11</sub>の乗算が行われる(但し、W<sub>11</sub> ≠ 0)(ステップS203)。従って、シナプス結合荷重W<sub>11</sub>の乗算を信号パルスS<sub>11</sub>の遅延のみで簡単に実行でき、シナプス結合演算部22<sub>11</sub>のゲート数を削減できる。

【0104】このとき、シナプス結合荷重W<sub>11</sub>が0であると(ステップS204; Y)、開閉スイッチ22<sub>211</sub>は、制御装置50の制御により接続ライン213<sub>11</sub>を遮断し、信号パルスDS<sub>11</sub>をインバータ214<sub>11</sub>に対して出力しないようにする(ステップS205)。これにより、シナプス結合荷重W<sub>11</sub>が“0”的場合の乗算が行われる。逆に、シナプス結合荷重W<sub>11</sub>が0でないと(ステップS204; N)、開閉スイッチ22<sub>211</sub>は、制御装置50の制御により接続ライン213<sub>11</sub>を遮断せず、信号パルスDS<sub>11</sub>をインバータ214<sub>11</sub>に対して出力するようとする。

【0105】インバータ214<sub>11</sub>は、シナプス結合演算部22<sub>11</sub>の出力が入力されると、信号を反転し、データバスライン212<sub>11</sub>を介してニューロン演算部23<sub>11</sub>に対し信号パルスDS<sub>11</sub>を出力する(ステップS206)。

【0106】ニューロン演算部23<sub>11</sub>の変換回路231<sub>11</sub>では、カウンタ2311<sub>11</sub>のOR<sub>231111</sub>に信号パルスDS<sub>11</sub>が入力されると、OR<sub>231111</sub>がフリップフロップFF<sub>231111</sub>のCLEAR端に信号“1”を出力する。これにより、フリップフロップFF<sub>231111</sub>の内部状態が“0”に設定され、ダウンカウンタDCNT<sub>231111</sub>の有効端ENABLEに出力端Qから信号“0”を出力はじめる。ダウンカウンタDCNT<sub>231111</sub>は、有効端ENABLEに信号“0”が入力されると、カウント動作を終了する。なお、データ入力装置10から信号パルスS<sub>11</sub>が出力されなかった場合およびシナプス結合演算部22<sub>11</sub>から信号パルスDS<sub>11</sub>が出力されなかった場合は、信号パルスDS<sub>11</sub>がOR<sub>231111</sub>に入力されないので、ダウンカウンタDCNT<sub>231111</sub>は“00000000”までダウンカウントを行う。ダウンカウンタDCNT<sub>231111</sub>は、カウント値が“00000000”となると桁借り信号Borrowを“0”から“1”とし、出力端BORROWから桁借り信号BorrowをOR<sub>231111</sub>を介してフリップフロップFF<sub>231111</sub>に出力し、その内部状態を“0”に設定する。フリップフロップFF<sub>231111</sub>は、ダウンカウンタDCNT<sub>231111</sub>の有効端ENABLEに出力端Qから信号“0”を出力し、ダウンカウンタDCNT<sub>231111</sub>のカウント動作を終了させる。これにより、カウント値CNT<sub>0</sub> ~ CNT<sub>7</sub> (すなわち信号パルスDS<sub>11</sub>と基準パルスB<sub>10</sub>とのパルス間隔T<sub>11</sub> t)が求められる(ステップS207) (図16参

10

20

30

40

50

照; ちなみに、図16では、遅延時間T<sub>11</sub> tが7tであり、カウント値CNT<sub>0</sub> ~ CNT<sub>7</sub>が“11000011”(10進数では195)である)。

【0107】ダウンカウンタDCNT<sub>231111</sub>は、カウント動作終了ののち、カウント値CNT<sub>0</sub> ~ CNT<sub>7</sub>を出力端Q<sub>0</sub> ~ Q<sub>7</sub>からルックアップテーブル2312<sub>11</sub>に対し出力する。ダウンカウンタDCNT<sub>231111</sub>は、そののち、制御装置50からLOAD端にSET\_DCNT信号が再び入力されると、データ端D<sub>0</sub> ~ D<sub>7</sub>に“11001001”を読み込む。

【0108】ルックアップテーブル2312<sub>11</sub>は、ダウンカウンタDCNT<sub>231111</sub>からカウント値CNT<sub>0</sub> ~ CNT<sub>7</sub>が入力されると、そのアドレスCNT<sub>0</sub> ~ CNT<sub>7</sub>に格納されたデータLT<sub>0</sub> ~ LT<sub>13</sub>を読み出し、加算回路232<sub>11</sub>に対して出力する。これにより、カウント値CNT<sub>0</sub> ~ CNT<sub>7</sub> (すなわちパルス間隔T<sub>11</sub> tの係数T<sub>11</sub> t)が指数変換され、対数変換された状態が解除される(ステップS208)。

【0109】加減算回路232<sub>11</sub>の選択回路2321<sub>11</sub>は、ルックアップテーブル2312<sub>11</sub>の出力データLT<sub>0</sub> ~ LT<sub>13</sub>が入力端A<sub>0</sub> ~ A<sub>13</sub>に入力されると、そのまま出力端Y<sub>0</sub> ~ Y<sub>13</sub>から加減算器2322<sub>11</sub>に対してデータLT<sub>0</sub> ~ LT<sub>13</sub>を出力する(ステップS209)。

【0110】加減算器2322<sub>11</sub>は、選択回路2321<sub>11</sub>からデータLT<sub>0</sub> ~ LT<sub>13</sub>が入力端A<sub>0</sub> ~ A<sub>13</sub>に入力されると、レジスタ2323<sub>11</sub>から入力端B<sub>0</sub> ~ B<sub>13</sub>にその保持データR<sub>0</sub> ~ R<sub>13</sub>を読み出す。その後、加減算器2322<sub>11</sub>は、制御装置50から制御端ADD/SUBへ入力された制御信号により加算か減算かを決定し、入力端A<sub>0</sub> ~ A<sub>13</sub>に入力された入力データLT<sub>0</sub> ~ LT<sub>13</sub>をレジスタ2323<sub>11</sub>の保持データR<sub>0</sub> ~ R<sub>13</sub>に対し加算または減算する(ステップS210)。なお、最初の信号LT<sub>0</sub> ~ LT<sub>13</sub>を処理するときは、レジスタ2323<sub>11</sub>の保持データR<sub>0</sub> ~ R<sub>13</sub>がゼロであるので、加減算器2322<sub>11</sub>は、入力端A<sub>0</sub> ~ A<sub>13</sub>への入力データLT<sub>0</sub> ~ LT<sub>13</sub>をゼロに加算または減算することになる。また、加減算器2322<sub>11</sub>の入力端A<sub>0</sub> ~ A<sub>13</sub>にデータLT<sub>0</sub> ~ LT<sub>13</sub>が入力される際には、データLT<sub>0</sub> ~ LT<sub>13</sub>の桁数が14であるのに対し入力端A<sub>0</sub> ~ A<sub>13</sub>の桁数が14+mであるので、14+1桁以上には“0”が補われる。加減算器2322<sub>11</sub>は、このようにして加減算した結果を、出力端S<sub>0</sub> ~ S<sub>13</sub>からレジスタ2323<sub>11</sub>に対して出力する。

【0111】レジスタ2323<sub>11</sub>は、加減算器2322<sub>11</sub>の出力がレジスタ2323<sub>11</sub>の入力端D<sub>0</sub> ~ D<sub>13</sub>に入力されると、書込端WTに制御装置50から制御信号WT\_REGを受信することにより、データを内部に保持する(ステップS211)。

【0112】ここで、加減算器2322<sub>11</sub>が信号パルス

$S_1, S_2, \dots, S_i, \dots, S_n$  にそれぞれ対応する全ての信号パルス  $DS_i$  \* について処理を行うまで (すなわち  $a$  回処理を行うまで) 、シナプス結合演算部 22<sub>1+1</sub>、変換回路 23<sub>1</sub> および加減算回路 23<sub>2</sub> は、次の基準パルス  $B_{10}$  および信号パルス  $S_{i+1}$  が入力されると、順次、ステップ S 201～ステップ S 211 を繰り返して行う (ステップ S 212)。

【0113】そののち、加減算回路 23<sub>2</sub> の選択回路 23<sub>21</sub> は、入力端  $B_0 \sim B_{13+1}$  への入力を出力に選択し、加減算器 23<sub>22</sub> に対してしきい値を出力する (ステップ S 213)。加減算器 23<sub>22</sub> は、ステップ S 210 と同様にして、レジスタ 23<sub>23</sub> の保持データ  $R_0 \sim R_{13+1}$  を読み出し、それに対し、しきい値の減算を行う (ステップ S 214)。

【0114】レジスタ 23<sub>23</sub> にしきい値を減算した後のデータが保持されると、シグモイド特性演算回路 23<sub>3</sub> は、レジスタ 23<sub>23</sub> から保持データ  $R_0 \sim R_{13+1}$  を読み出しデータ入力端  $AD_0 \sim AD_{13}$  に入力する。このとき、アドレス  $R_0 \sim R_{13+1}$  のうち下 m 桁は切り捨てる。シグモイド特性演算回路 23<sub>3</sub> は、アドレス  $R_0 \sim R_{13+1}$  が入力されると、アドレス  $R_0 \sim R_{13+1}$  に格納されたデータ  $D_0 \sim D_6$  を読み出し、パルス発生回路 23<sub>4</sub> に対して出力する。これにより、シグモイド関数変換と対数変換がされる (ステップ S 215)。

【0115】パルス発生回路 23<sub>4</sub> は、制御装置 50 から SET\_UCNT 信号を受信することにより、アップカウンタ  $UCNT_{234}$  のデータ端  $D_0 \sim D_6$  にシグモイド特性演算回路 23<sub>3</sub> の出力データ  $G_0 \sim G_6$  を読み込む (ステップ S 216)。

【0116】次いで、パルス発生回路 23<sub>4</sub> に制御装置 50 から基準パルス  $B_{20}$  が発信され、フリップフロップ  $FF_{234}$  の入力端 SET に入力されると、パルス発生回路 23<sub>4</sub> は、データ入力装置 10 のパルス発生回路 14<sub>1</sub> と同様にして、信号パルス  $S_i$  を出力端 CARR Y から演算装置 30 に対して出力する。これにより、演算装置 20 の出力端 V<sub>i</sub> から信号パルス  $S_i$  が演算装置 30 に対して出力される (ステップ S 217)。

#### 【0117】演算装置 30 での動作

【0118】演算装置 30 では、シグモイド特性演算回路 33<sub>31</sub>, 33<sub>32</sub>, …, 33<sub>3k</sub>, …, 33<sub>3</sub> が対数変換を行わないこと、およびパルス発生回路による処理を行わないことを除き、演算装置 20 と同様の処理動作を行う。従って、ここではその詳細な説明は省略する。なお、シグモイド特性演算回路 33<sub>31</sub>, 33<sub>32</sub>, …, 33<sub>3k</sub>, …, 33<sub>3</sub> は、その出力を表示装置 40 に対して行う。

#### 【0119】表示装置 40 での動作

【0120】表示装置 40 では、演算装置 30 から 2 進数で表現されたデータ  $I_1, I_2, \dots, I_k, \dots, I_n$  が各入力端  $I_1, I_2, \dots, I_k, \dots, I_n$  にそれぞれ入力され

ると、そのデータをそれぞれ表示する。例えば、初期設定においてアルファベット 26 文字を識別するようにシナプス結合荷重  $W$  を設定した場合には、演算装置 30 からアルファベット文字に 1 つづつ対応された 26 個のデータ  $I$  が入力され、その中の 1 つが大きな値を示すようになる。

#### 【0121】演算速度

【0122】ここで、本実施例のニューラルネットワークの演算速度について説明する。ここにおいては、説明を簡素化する目的で、データ入力装置 10 の認識素子 1 1 の数を 1000 (すなわち  $a = 1000$ )、演算装置 20, 30 のそれぞれのニューロン演算部 23, 33 の数を 1000 (すなわち  $b, c = 1000$ )、クロックの周波数を 200 MHz (クロック周期は 5 ns (すなわち遅延時間の 1 単位  $t = 5 ns$ )) として説明する。

【0123】まず、データ入力装置 10 の 1 つのパルス発生回路 14<sub>1</sub> が演算装置 20 に信号パルス  $S_i$  を出力するに必要な時間は、信号パルス  $S_i$  の基準パルス  $B_{10}$  に対する遅延時間が最大 101t であるので、101 にクロック周期 5 ns をかけた 505 ns である。次に、演算装置 20 の遅延素子 22<sub>11</sub> が信号パルス  $S_i$  を遅延させるに必要な時間は、最大 100t であるので、500 ns である。よって、演算装置 20 の変換回路 23<sub>1</sub> が信号パルス  $DS_i$  \* の遅延時間を測定するに必要な時間は、最大 201t すなわち 1005 ns である。

【0124】また、ニューロン演算部 23<sub>1</sub> では、データ入力装置 10 のパルス発生装置 14<sub>1</sub> が出力する全ての信号パルス  $S_i$  について処理をするので、ここでは、1000 回処理を行うことになる。よって、それに必要な時間は、1005 ns に 1000 をかけた 1005 μs (すなわち約 1 ms) である。なお、各ニューロン演算部 23<sub>1</sub>, 23<sub>2</sub>, …, 23<sub>1</sub>, …, 23<sub>6</sub> はそれぞれ並列して処理をおこなうので、演算装置 20 の必要な処理時間は、この時間と同一であり、1 ms である。よって、ニューラルネットワーク全体 (すなわち演算装置 20 と演算装置 30 あわせて) の処理時間は、2 ms である。

【0125】また、このニューラルネットワークの 1 秒間あたりの処理結合数は、結合数が 200 万 ( $1000 \times 1000 \times 2 = 200$  万) であるので、 $200\text{万} / 2\text{ ms} = 1\text{ GCPs}$  (Giga Connections Per Second) である。一般的なニューラルネットワークの 1 秒間あたりの処理結合数が、数百 MCPs (Mega Connections Per Second) であることと比較すると、高速処理が可能となることがわかる。

#### 【0126】(第 1 の実施例の効果)

【0127】このように、本実施例によれば、遅延素子によりシナプス結合荷重  $W$  の乗算を実行するので、乗算器に比べて回路規模を小さくでき、高集積化を図ること

ができる。また、ニューロン演算回路への入力または出力をパルスにより行うことができ、演算精度を高精度とできる。更に、ハードウェアによりニューラルネットワークを実現でき、高速演算を可能とできる。加えて、遅延素子の遅延時間の設定を容易に変更することができ、すなわちシナプス結合荷重Wを容易に変更できる。

【0128】(第2の実施例)

【0129】次に、第2の実施例について、その構成および作用を説明する。図19は、第2の実施例に係るニューラルネットワークのための回路の構成を表すものである。

【0130】本実施例の回路は、シナプス結合演算を行うためのシナプス結合演算回路60と、ニューロンモデルを実現するためのニューロン演算回路70と、シナプス結合演算回路60とニューロン演算回路70とを接続する配線に対し配設された共通負荷80とを備えている。

【0131】シナプス結合演算回路60は、a個の入力端 $S_1, S_2, \dots, S_1, \dots, S_a$ とb個の出力端 $D_{S_1}, D_{S_2}, \dots, D_{S_1}, \dots, D_{S_b}$ とをそれぞれ互いに接続するための配線24と、各入力端 $S_1, S_2, \dots, S_1, \dots, S_a$ と各出力端 $D_{S_1}, \dots, D_{S_2}, \dots, D_{S_1}, \dots, D_{S_b}$ との間にそれぞれ挿入された $a \times b$ 個のシナプス結合演算部 $22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}; 22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}$ とを備えている。

【0132】配線24は、共通負荷 $215_1, 215_2, \dots, 215_1, \dots, 215_b$ が削除されたことを除き、第1の実施例の配線21と同一の構成を有している。各シナプス結合演算部 $22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}; 22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}$ のそれぞれは、第1の実施例のシナプス結合演算部 $22_{11}$ と同一の構成を有している。従って、同一の構成要素にはそれぞれ同一の符号を付して、それらの詳細な説明は省略する。

【0133】ニューロン演算回路70は、b個のニューロン演算部 $23_1, 23_2, \dots, 23_1, \dots, 23_b$ を備えている。このニューロン演算部 $23_1, 23_2, \dots, 23_1, \dots, 23_b$ のそれぞれは、第1の実施例のニューロン演算部 $23_1$ と同一の構成を有しているので、同一の構成要素には同一の符号を付して、その詳細な説明は省略する。

【0134】すなわち、本実施例の回路は、第1の実施例の演算装置20の各シナプス結合演算部 $22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}; 22_{11}, 22_{12}, \dots, 22_{1j}, \dots, 22_{1b}; 22_{21}, 22_{22}, \dots, 22_{2j}, \dots, 22_{2b}$ と、

各ニューロン演算部 $23_1, 23_2, \dots, 23_1, \dots, 23_b$ とを分離したものである。

【0135】本実施例の回路は、このように、シナプス結合演算回路60とニューロン演算回路70とを分離しているので、図20に表すように、これらを複数組み合わせることにより、ニューラルネットワークの結合数を自由に増加することができる。

【0136】なお、上記説明では、シナプス結合演算回路60の出力端 $DS^*$ の数bと、ニューロン演算回路70のニューロン演算部 $23$ の数bとを同一として説明したが、これに限るものではなく、ニューロン演算部 $23$ の数をcとし、シナプス結合演算回路60の出力端 $DS^*$ の数bと相違してもよい。

【0137】以上実施例を挙げて本発明を説明したが、本発明は上記実施例に限定されるものではなく、その均等の範囲で種々変形可能である。例えば、本発明は、相互結合型のニューラルネットワークなどを構築した場合にも適用可能である。

【0138】

【発明の効果】以上説明したように請求項1ないし請求項3記載のニューラルネットワークによれば、信号パルスを遅延させることによりシナプス結合荷重の乗算を実行するので、(i)回路規模を小さくでき、高集積化を図ることができるという効果を奏する。また、(ii)ニューロンモデルへの入力をパルスにより行うことができ、演算精度を高精度とできるという効果を奏する。更に、(iii)ハードウェアによりニューラルネットワークを実現でき、高速演算を可能とできるという効果を奏する。

【0139】特に、請求項2記載のニューラルネットワークによれば、シナプス結合演算手段を遅延時間の設定または変更が容易な遅延素子により構成するので、(iv)シナプス結合荷重を容易に変更できるという効果を奏する。

【0140】更に、請求項3記載のニューラルネットワークによれば、シナプス結合演算手段が開閉スイッチをそなえているので、(v)シナプス結合荷重がゼロであっても容易に対応可能とできるという効果を奏する。

【0141】また、請求項4ないし請求項8記載のシナプス結合演算回路によれば、(vi)ニューロンモデルへの各入力に対するシナプス結合荷重の乗算を信号の遅延により実行することができるという効果を奏する。すなわち、このシナプス結合演算回路を用いることにより、上記(i)～(iii)の効果を奏するニューラルネットワークを構築できるという効果を奏する。

【0142】特に、請求項7記載のシナプス結合演算回路によれば、上記(iv)の効果を奏し、更に、請求項8記載のシナプス結合演算回路によれば、上記(v)の効果を奏する。

【0143】加えて、請求項5または請求項6記載のシナプス結合演算回路によれば、データバスラインにより

すくなくとも1以上のシナップス結合演算手段からの出力を1つにまとめるので、(vii)配線の数を減少できるという効果を奏する。すなわち、配線を簡素化でき、回路の設計を容易とできるという効果を奏する。

【0144】加えてまた、請求項4ないし請求項8記載のシナップス結合演算回路によれば、(viii)複数結合することによりニューロンモデルへの入力数を自由に増加することができるという効果を奏する。

【0145】更に、請求項9のニューロン演算回路によれば、ニューロンモデルへの入力を2進数に変換したのち指数変換したニューロンモデルからの出力を対数変換したのちパルス信号に変換するので、(ix)シナップス結合荷重の乗算を信号パルスの基準パルスに対する遅延時間の加算に変換できるという効果を奏する。すなわち、このニューロン演算回路を用いることにより、上記(i)～(iii)の効果を奏するニューラルネットワークを構築できるという効果を奏する。また、(x)複数結合することによりニューロンモデルの数を自由に増加することができるという効果を奏する。

【0146】加えて、請求項10のニューラルネットワークのための回路によれば、上記(vi)および(ix)の効果を奏する。すなわち、この回路を用いることにより、上記(i)～(iii)の効果を奏するニューラルネットワークを構築できるという効果を奏する。

#### 【図面の簡単な説明】

【図1】本発明の第1の実施例に係るニューラルネットワークの構成を表すブロック図である。

【図2】図1に示した実施例のデータ入力装置の構成を表すブロック図である。

【図3】図2に示したデータ入力装置の認識素子、レジスタ、ルックアップテーブルおよびパルス発生回路のそれぞれの構成を表す回路図である。

【図4】図1に示した実施例の中間層としての演算装置の構成を表す回路図である。

【図5】図4に示した演算装置のシナップス結合演算部の構成を表す回路図である。

【図6】図4に示した演算装置のニューロン演算部の構成を表すブロック図である。

【図7】図6に示したニューロン演算部の変換回路の構成を表す回路図である。

【図8】図6に示したニューロン演算部の加減算回路の構成を表す回路図である。

【図9】図6に示したニューロン演算部のシグモイド特性演算回路の構成を表す回路図である。

【図10】図9に示したシグモイド特性演算回路で行うシグモイド関数変換のシグモイド関数の特性を表すグラフである。

【図11】図6に示したニューロン演算部のパルス発生回路の構成を表す回路図である。

【図12】図1に示した実施例の出力層としての演算装置の構成を表す回路図である。

【図13】図12に示した演算装置のニューロン演算部の構成を表す回路図である。

【図14】図1に示した実施例のデータ入力装置の処理動作を説明するための流れ図である。

【図15】図1に示した実施例のデータ入力装置の処理動作を説明するための流れ図である。

【図16】図1に示した実施例のクロック、基準パルス  $B_{10}$ 、信号パルス  $S_1$  および信号パルス  $D S_{11}$  との関係を説明するための波形図である。

【図17】図1に示した実施例の中間層としての演算装置の処理動作を説明するための流れ図である。

【図18】図1に示した実施例の中間層としての演算装置の処理動作を説明するための流れ図である。

【図19】本発明の第2の実施例に係る集積回路の構成を表す回路図である。

【図20】図19に示した実施例の一使用態様を説明するための構成図である。

#### 【符号の説明】

10 データ入力装置

11 認識素子

12 レジスタ

13 ルックアップテーブル

14 パルス発生回路

20, 30 演算装置

21, 31, 24 配線

211, 311 入力ライン

212, 312 データバスライン

22, 32 シナップス結合演算部

221, 321 遅延素子

222, 322 開閉スイッチ

23, 33 ニューロン演算部

231, 331 変換回路

2311, 3311 カウンタ

2312, 3312 ルックアップテーブル

232, 332 加減算回路

40 233, 333 シグモイド特性演算回路

234 パルス発生回路

40 表示装置

50 制御装置

60 シナップス結合演算回路

70 ニューロン演算回路

80 共通負荷

【図1】



【図10】



【図14】



【図2】



【図15へ】

【図5】



【図13】



【図3】



【図4】



【図6】



【図7】



【図9】



【図11】



【図8】



【図12】



【図15】



【図20】



【図16】



【図17】



図18から

[図18]



[図19]

